package com.billard.mapper;

import com.billard.entity.Table;
import com.billard.vo.TableVO;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.time.LocalDateTime;
import java.util.List;
import java.util.Map;

/**
 * 球台Mapper接口
 */
@Mapper
public interface TableMapper {

    /**
     * 查询所有球台
     */
    List<Table> selectAll();

    /**
     * 根据ID查询球台
     */
    Table selectById(@Param("id") Long id);

    /**
     * 根据状态查询球台
     */
    List<Table> selectByStatus(@Param("status") Integer status);

    /**
     * 查询球台使用统计数据
     */
    List<Map<String, Object>> selectTableUsageStats(@Param("startTime") LocalDateTime startTime,
                                                    @Param("endTime") LocalDateTime endTime);

    /**
     * 查询球台统计
     */
    Map<String, Object> selectTableStats();

    /**
     * 插入球台
     */
    int insert(Table table);

    /**
     * 更新球台
     */
    int update(Table table);

    /**
     * 删除球台
     */
    int deleteById(@Param("id") Long id);

    /**
     * 更新球台状态
     */
    int updateStatus(@Param("id") Long id, @Param("status") Integer status);
}
